<template>
	<view class="grade" :class="[isDark?'dark':'']"  :style="{'background-color':isDark?'#1c1c1c':'#f6f6f6','min-height':isDark?'100vh':'auto'}">
		<view class="header" style="color: white;" :style="[{height:CustomBar + 'px'}]">
			<view class="cu-bar" style="background-color: transparent !important;"
				:style="{'height': CustomBar + 'px','padding-top':StatusBar + 'px'}">
				<view class="action" style="color: white;" @tap="goBack">
					<text class="tn-icon-left text-bold text-white"></text>
				</view>
				<view class="text-bold text-white" :style="[{top:StatusBar + 'px'}]">
					{{$t('user.signin.dailysignin')}}
				</view>
				<view class="action text-white" style="color: white;" @tap="showModal" data-target="Modal">
					<text class="tn-icon-tip text-bold"></text>
				</view>
			</view>
		</view>
		<view class="top" :style="{'background-color':isDark?'#1c1c1c':'#ffffff'}">
			<image class="line" src="../../static/user/arc.png"></image>
			<view class="num">
				<view>
					<image src="../../static/user/grade.png"></image>
					<p style="font-size: 10px;" :style="{'color':isDark?'#ffffff':'#000000'}">Lv.{{levelfirst}}</p>
				</view>
				<view>
					<image src="../../static/user/grade.png"></image>
					<text :style="{'color':isDark?'#ffffff':'#000000'}">Lv.{{level}}</text>
				</view>
				<view>
					<image src="../../static/user/grade.png"></image>
					<p style="font-size: 10px;" :style="{'color':isDark?'#ffffff':'#000000'}">Lv.{{levellast}}</p>
				</view>
			</view>
			<view class="numerical">
				<view class="experience">
					<text class="pre" :style="{'color':isDark?'#000':'#ffffff'}">{{$t('user.signin.nowexperience')}}:</text>
					<text class="expNum" :style="{'color':isDark?'#000':'#ffffff'}">{{experience}}</text>
				</view>
			</view>
		</view>
		<view class="cont" :style="{'background-color':isDark?'#1c1c1c':'#ffffff'}">
			<view class="experience2" :style="{'background-color':isDark?'#1c1c1c':'#ffffff', 'border':isDark?'1px solid #2c2c2c':'1px solid #e5e5e5'}">
				<text class="title" :style="{'color':isDark?'#ffffff':'#000000'}">{{$t('user.signin.experienced')}}:{{experience}}</text>

				<tn-line-progress :percent="percentage" activeColor="#3cc9a4" :height="36" :striped="true"
					:stripedAnimation="true"></tn-line-progress>
				<view class="number">
					<text :style="{'color':isDark?'#ffffff':'#000000'}">Lv.{{level}}</text>
					<text :style="{'color':isDark?'#ffffff':'#000000'}">{{$t('user.signin.nextlevel') + postflowExp + $t('user.signin.experien')}}</text>
					<text :style="{'color':isDark?'#ffffff':'#000000'}">Lv.{{levellast}}</text>
				</view>
			</view>
			<view class="experience" :style="{'background-color':isDark?'#1c1c1c':'#ffffff', 'border':isDark?'1px solid #2c2c2c':'1px solid #e5e5e5'}">
				<text class="title" :style="{'color':isDark?'#ffffff':'#000000'}">{{$t('global.signin') + leiji + $t('global.day')}}</text>
				<br>
				<view class="gift">
					<view class="item" v-for="(item,index) in dayList" :key="index">
						<view :class="item.state == 1?'special':''">
							<image :src="item.state == 1?giftYel:giftRed"></image>
						</view>
						<text :style="{'color':isDark?'#ffffff':'#000000'}">+{{item.jy}}</text>
					</view>
				</view>
				<br>
				<view class="gift">
					<view class="item" v-for="(item,index) in dayList" :key="index">
						<view :class="item.state == 1?'special':''">
							<image :src="item.state == 1?giftexp2:giftexp"></image>
						</view>
						<text :style="{'color':isDark?'#ffffff':'#000000'}">+{{item.exp}}</text>
					</view>
				</view>
				<view class="button-group">
					<view class="button" @tap="qiandao()">
						<text>{{$t('user.signin.nowsignin')}}</text>
					</view>
					<view class="button" @tap="torenwu()">
						<text>{{$t('user.signin.taskcenter')}}</text>
					</view>
				</view>
			</view>
			<view class="cu-modal" :class="modalName=='Modal'?'show':''" style="padding: 15px 15px;">
				<view class="cu-dialog" style="border-radius: 15px" :style="{'background-color':isDark?'#1c1c1c':'#ffffff'}">
					<view class="cu-bar justify-end" :style="{'background-color':isDark?'#1c1c1c':'#ffffff'}">
						<view class="content" :style="{'color':isDark?'#ffffff':'#000000'}">{{$t('user.signin.leveldesc')}}</view>
					</view>
					<view class="padding text-left" :style="{'background-color':isDark?'#1c1c1c':'#ffffff', 'color':isDark?'#cccccc':'#666666'}" v-html="jingyantext">
					</view>
					<view class="padding text-center" :style="{'background-color':isDark?'#1c1c1c':'#ffffff'}">
						<tn-button style="margin-left: 20rpx;" :backgroundColor="isDark?'#2c2c2c':'#3cc9a4'" fontColor="#fff"
							@tap="hideModal">{{$t('global.good')}}</tn-button>
					</view>
				</view>
			</view>

		</view>
	</view>
</template>

<script>
	import waves from '@/components/xxley-waves/waves.vue';
	import {
		localStorage
	} from '../../js_sdk/mp-storage/mp-storage/index.js'
	import darkModeMixin from '@/utils/darkModeMixin.js'
	export default {
		mixins: [darkModeMixin],
		data() {
			return {
				StatusBar: this.StatusBar,
				CustomBar: this.CustomBar,
				NavBar: this.StatusBar + this.CustomBar,
				userInfo: {
					name: ''
				},
				modalName: null,
				uid: 0,
				experience: 0,
				currentLevel2: 0,
				nextLevelExp2: 0,
				remainingExp2: 0,
				allExp: 0,
				levelfirst: 0,
				leiji: 0,
				continuous: 0,
				jingyan: 0,
				token: '',
				percentage: 0,
				level: 0,
				levellast: 0,
				jingyantext: "",
				overflowExp: 0,
				tempArr: [],
				postflowExp: 0,
				giftexp: "../../static/user/jy2.png",
				giftexp2: "../../static/user/jy1.png",
				giftRed: "../../static/user/ld2.png",
				giftYel: "../../static/user/ld1.png",
				dayList: [{
						exp: 0,
						jy: 0,
						state: 0,
					},
					{
						exp: 0,
						jy: 0,
						state: 0,
					},
					{
						exp: 0,
						jy: 0,
						state: 0,
					},
					{
						exp: 0,
						jy: 0,
						state: 0,
					},
					{
						exp: 0,
						jy: 0,
						state: 0,
					},
					{
						exp: 0,
						jy: 0,
						state: 0,
					},
					{
						exp: 0,
						jy: 0,
						state: 1,
					}
				]
			}
		},

		created() {
			uni.$on('refreshPage', () => {
				this.percent();
			});
		},
		onShow() {
			var that = this;
			// #ifdef APP-PLUS
			uni.hideTabBar({
				animation: false
			})

			plus.navigator.setStatusBarStyle("light")
			// #endif
			if (localStorage.getItem('userinfo')) {
				that.userInfo = JSON.parse(localStorage.getItem('userinfo'));
				that.token = that.userInfo.token;
				that.uid = that.userInfo.uid;
			}
			that.userStatus();
		},

		onLoad() {
			var that = this;
			// #ifdef APP-PLUS || MP
			that.NavBar = that.CustomBar;
			plus.navigator.setStatusBarStyle('light');
			// #endif
		},
		mounted() {
			this.getContinuous();
			this.getqdjl();
			this.getset();
		},
		methods: {
			getset() {
				var that = this;
				uni.request({
					url: that.$API.SPset(),
					method: 'GET',
					dataType: "json",
					success(res) {
						that.jingyantext = res.data.jingyantext;
					},
					fail(error) {
						
					}
				})
			},
			userStatus() {
				var that = this;
				that.$Net.request({

					url: that.$API.userStatus(),
					data: {
						"token": that.token
					},
					header: {
						'Content-Type': 'application/x-www-form-urlencoded'
					},
					method: "get",
					dataType: 'json',
					success: function(res) {
						if (res.data.code == 0) {
							
						} else {
							if (localStorage.getItem('userinfo')) {
								var userInfo = JSON.parse(localStorage.getItem('userinfo'));
								that.uid = res.data.data.uid;
								localStorage.setItem('userinfo', JSON.stringify(userInfo));
								// if(res.data.data.avatar){
								// 	that.userInfo = res.data.data.avatar;
								// }
							}
							that.experience = res.data.data.experience;
							that.loadData();

						}
					},
					fail: function(res) {
						uni.showToast({
							title: that.$t('common.networkfail'),
							icon: 'none'
						})
					}
				})
			},

			showModal(e) {
				this.modalName = e.currentTarget.dataset.target
			},
			hideModal(e) {
				this.modalName = null
			},
			getContinuous() {
				var that = this;
				uni.request({
					url: that.$API.SPleiji(),
					method: 'GET',
					data: {
						uid: that.uid
					},
					dataType: "json",
					success(res) {
						that.leiji = res.data.leiji;
					},
					fail(error) {
						
					}
				})
			},
			getqdjl() {
				var that = this;
				uni.request({
					url: that.$API.SPqiandaojl(),
					method: 'GET',
					data: {
						uid: that.uid
					},
					dataType: "json",
					success(res) {
						var tempArr = [{
								jy: res.data.assets_1day,
								exp: res.data.experience_1day
							},
							{
								jy: res.data.assets_2day,
								exp: res.data.experience_2day
							},
							{
								jy: res.data.assets_3day,
								exp: res.data.experience_3day
							},
							{
								jy: res.data.assets_4day,
								exp: res.data.experience_4day
							},
							{
								jy: res.data.assets_5day,
								exp: res.data.experience_5day
							},
							{
								jy: res.data.assets_6day,
								exp: res.data.experience_6day
							},
							{
								jy: res.data.assets_7day,
								exp: res.data.experience_7day
							},
						];
						for (var i = 0; i < that.dayList.length; i++) {
							if (tempArr[i].jy) {
								that.dayList[i].jy = tempArr[i].jy;
							}
							if (tempArr[i].exp) {
								that.dayList[i].exp = tempArr[i].exp;
							}
						}
					},
					fail(error) {
						
					}
				})
			},
			goBack() {
				uni.navigateBack({
					delta: 1
				});
			},
			torenwu() {
				uni.navigateTo({
					url: '/pages/user/task'
				});
			},

			qiandao() {
				var that = this;

					uni.request({
						url: that.$API.SPqiandao(),
						method: 'GET',
						data: {
							uid: that.token
						},
						dataType: "json",
						success(res) {
							uni.showToast({
								title: res.data.msg,
								icon: 'none',
							});
							that.loadData();
							that.userStatus();
							uni.$emit('refreshPage');
							
						},
						fail() {
							uni.showToast({
								title: that.$t('user.signin.signinfail'),
								icon: 'none',
							});
							that.loadData();
							uni.$emit('refreshPage');
						}
					})

			},
			percent() {
				const expPerLevel = [0, 10, 50, 200, 500, 1000, 2000, 5000, 10000];
				const currentExp = this.experience; // 当前经验值
				const currentLevel = expPerLevel.findIndex(exp => currentExp < exp);
				const currentLevel2 = currentLevel - 1;
				const nextLevelExp = expPerLevel[currentLevel];
				const nextLevelExp2 = expPerLevel[currentLevel2];
				const remainingExp = nextLevelExp - currentExp;
				const allExp = nextLevelExp - nextLevelExp2;
				const remainingExp2 = allExp - remainingExp;
				
				if (currentExp >= 10000) {
					this.level = this.$t('user.signin.maxed');
					this.levellast = this.$t('user.signin.maxed');
					this.levelfirst = this.$t('user.signin.maxed');
					this.percentage = 100;
				} else {
					this.level = currentLevel; // 等级
					
					if (currentExp >= 10000) {
						this.levellast = this.$t('user.signin.maxed'); // 下一等级
					}else{
						this.levellast = currentLevel + 1; // 下一等级
					}
					this.levelfirst = currentLevel - 1; // 上一等级
					this.postflowExp = remainingExp; // 距离
					this.remainingExp2 = remainingExp2; // 溢出
					this.allExp = allExp; // 本级和下级需要的经验
					this.percentage = Math.floor((remainingExp2 / allExp) * 100); // 计算进度条百分比
				}
			},
			loadData() {
				var that = this;
				that.percent();
			}
		}
	}
</script>

<style lang="scss" scoped>
	.grade {
		& text {
			font-family: PingFangSC-Semibold, PingFang SC;
		}

		.bar {
			.left image {
				width: 48rpx;
				height: 48rpx;
			}

			.center text {
				font-size: 32rpx;
				font-weight: 600;
				color: #FFFFFF;
				line-height: 44rpx;
			}

			.right {
				width: 148rpx;
				height: 44rpx;
				background: #3cc9a4;
				border-radius: 22rpx 0 0 22rpx;
				border: 2rpx solid #FFFFFF;
				text-align: center;
				margin-right: -34rpx;

				>text {
					font-size: 24rpx;
					font-family: PingFangSC-Regular, PingFang SC;
					color: #FFFFFF;
					line-height: 44rpx;
				}
			}
		}

		.top {
			width: 750rpx;
			height: 450rpx;
			padding: 0 50rpx;
			border-radius: 0 0 50% 50%/0 0 15% 15%;
			background: linear-gradient(360deg, #44e4ba 0%, #28866b 100%);

			.line {
				width: 100%;
				height: 142rpx;
				margin-top: 88rpx;
			}

			.num {
				display: flex;
				justify-content: center;
				margin-top: -84rpx;

				>view {

					width: 144rpx;
					height: 136rpx;
					justify-content: center;
					align-items: center;
					display: flex;

					& image {
						width: 144rpx;
						height: 136rpx;

					}

					& text {
						font-size: 40rpx;
						font-weight: 600;
						color: #999999;
						line-height: 90rpx;
						text-shadow: 0rpx 2rpx 1rpx rgba(0, 0, 0, 0.0200);
						background: linear-gradient(to bottom right, #ff9326, #df5557);
						-webkit-background-clip: text;
						-webkit-text-fill-color: transparent;
						position: absolute;
					}

					& p {
						font-size: 40rpx;
						font-weight: 600;
						color: #999999;
						line-height: 90rpx;
						text-shadow: 0rpx 2rpx 1rpx rgba(0, 0, 0, 0.0200);
						background: linear-gradient(to bottom right, #939393, #414141);
						-webkit-background-clip: text;
						-webkit-text-fill-color: transparent;
						position: absolute;
					}

					&:nth-child(2) {
						margin: 0 52rpx;
					}

					&:nth-child(1),
					&:nth-child(3) {
						margin-top: -40rpx;

						>image {
							width: 104rpx;
							height: 100rpx;
						}

						>text {
							font-size: 40rpx;
						}
					}

				}
			}

			.numerical {
				display: flex;
				flex-direction: column;
				align-items: center;
				margin-top: 24rpx;

				.experience {
					display: flex;
					align-items: center;

					.pre {
						font-size: 28rpx;
						color: #FFFFFF;
						line-height: 40rpx;
					}

					>image {
						width: 36rpx;
						height: 30rpx;
						margin: 0 6rpx;
					}

					.expNum {
						font-size: 36rpx;
						font-weight: 600;
						color: #FFFFFF;
					}
				}

				.differ {
					>text {
						font-size: 20rpx;
						color: #999999;
						line-height: 42rpx;
					}
				}
			}
		}

		.cont {
			padding: 0 40rpx;

			.people {
				width: 100%;
				height: 116rpx;
				background: linear-gradient(90deg, #43e3b9 0%, #3cc9a4 51%, #39bf9b 100%);
				border-radius: 58rpx;
				margin-top: 12rpx;
				padding: 0 36rpx 0 18rpx;
				display: flex;
				align-items: center;

				.image {
					width: 84rpx;
					height: 84rpx;
					display: flex;
					justify-content: center;
					align-items: center;
					margin-right: 20rpx;

					>image {
						width: 84rpx;
						height: 84rpx;
						border-radius: 50%;
					}

					>view {
						width: 92rpx;
						height: 92rpx;
						border-radius: 50%;
						border: 2rpx solid #FFFFFF;
						filter: blur(2rpx);
						position: absolute;
					}
				}

				.text {
					flex: 1;
					display: flex;
					align-items: center;

					>text:first-child {
						font-size: 36rpx;
						font-weight: 600;
						color: #FFFFFF;
						line-height: 50rpx;
						margin-right: 14rpx;
					}

					>text:last-child {
						height: 34rpx;
						background: #BDA3FF;
						border-radius: 17rpx;
						padding: 0 14rpx;
						font-size: 24rpx;
						color: #FFFFFF;
						line-height: 34rpx;
					}
				}

				.money {
					display: flex;
					flex-direction: column;

					>text:first-child {
						font-size: 36rpx;
						font-weight: 600;
						color: #FFFFFF;
						line-height: 50rpx;
					}

					>text:last-child {
						font-size: 24rpx;
						color: #DBCDFF;
						line-height: 34rpx;
					}
				}
			}

			.experience {
				width: 100%;
				height: 600rpx;
				background: #FFFFFF;
				border-radius: 20rpx;
				padding: 40rpx 18rpx;
				margin-top: 24rpx;

				.title {
					display: block;
					font-size: 32rpx;
					font-weight: 600;
					color: #333333;
					line-height: 44rpx;
					margin-bottom: 22rpx;
				}

				.number {
					display: flex;
					margin: 22rpx 0 56rpx 0;
					justify-content: space-between;

					>text {
						font-size: 28rpx;
						font-weight: 600;
						color: #000000;
						line-height: 40rpx;

						&:nth-child(2) {
							font-size: 28rpx;
							font-weight: 400;
							color: #999999;
							line-height: 40rpx;
						}
					}
				}

				.gift {
					display: flex;

					.item {
						display: flex;
						flex-direction: column;
						align-items: center;
						margin-right: 22rpx;

						>view {
							width: 70rpx;
							height: 70rpx;
							background: #FFF0F0;
							border-radius: 20rpx;
							display: flex;
							justify-content: center;
							align-items: center;

							>image {
								width: 36rpx;
								height: 36rpx;
							}
						}

						.special {
							background: #FFFAF0;
						}

						>text {
							font-size: 20rpx;
							color: #999999;
							line-height: 28rpx;
							margin-top: 4rpx;
						}
					}
				}

				.button-group {
					display: flex;
					flex-direction: row;
					justify-content: space-around;
				}

				.button {
					width: 300rpx;
					height: 100rpx;
					margin: auto;
					margin-top: 60rpx;
					background: linear-gradient(90deg, #44e9bd 0%, #3cc9a4 100%);
					border-radius: 58rpx;
					text-align: center;

					>text {
						font-size: 32rpx;
						font-weight: 600;
						color: #FFFFFF;
						line-height: 100rpx;
					}
				}
			}

			.experience2 {
				width: 100%;
				height: 300rpx;
				background: #FFFFFF;
				border-radius: 20rpx;
				padding: 40rpx 18rpx;
				margin-top: 24rpx;

				.title {
					display: block;
					font-size: 32rpx;
					font-weight: 600;
					color: #333333;
					line-height: 44rpx;
					margin-bottom: 22rpx;
				}

				.number {
					display: flex;
					margin: 22rpx 0 56rpx 0;
					justify-content: space-between;

					>text {
						font-size: 28rpx;
						font-weight: 600;
						color: #000000;
						line-height: 40rpx;

						&:nth-child(2) {
							font-size: 28rpx;
							font-weight: 400;
							color: #999999;
							line-height: 40rpx;
						}
					}
				}
			}

			.task {
				width: 100%;
				height: 630rpx;
				background: #FFFFFF;
				border-radius: 20rpx;
				margin-top: 24rpx;
				padding: 40rpx 30rpx 0 20rpx;
				display: flex;
				flex-direction: column;

				.title {
					font-size: 32rpx;
					font-family: PingFangSC-Semibold, PingFang SC;
					font-weight: 600;
					color: #333333;
					line-height: 44rpx;
				}

				.text {
					font-size: 24rpx;
					color: #999999;
					line-height: 34rpx;
					margin: 6rpx 0 22rpx 0;
				}

				.list {
					display: flex;
					justify-content: space-between;
					margin-bottom: 74rpx;

					>view {
						width: 92rpx;
						height: 116rpx;
						background: linear-gradient(90deg, #41dbb2 0%, #3cc9a4 100%);
						border-radius: 6rpx;
						display: flex;
						flex-direction: column;
						justify-content: center;
						align-items: center;

						>image {
							width: 58rpx;
							height: 56rpx;
						}

						>text {
							font-size: 20rpx;
							color: #FFFFFF;
							line-height: 28rpx;
							margin-top: 6rpx;
						}
					}
				}

				.invitation {
					.item {
						display: flex;
						align-items: center;
						margin-bottom: 36rpx;

						.icon {
							width: 84rpx;
							height: 84rpx;
							border-radius: 50%;
							background: #F5F1FF;
							display: flex;
							justify-content: center;
							align-items: center;
							margin-right: 14rpx;

							>image {
								width: 60rpx;
								height: 60rpx;
							}
						}

						.cent {
							flex: 1;
							display: flex;
							flex-direction: column;

							>text:first-child {
								font-size: 28rpx;
								color: #333333;
								line-height: 40rpx;
							}

							>text:last-child {
								font-size: 24rpx;
								color: #999999;
								line-height: 34rpx;
							}
						}

						.complete {
							width: 122rpx;
							height: 52rpx;
							background: linear-gradient(90deg, #43e2b8 0%, #3cc9a4 100%);
							border-radius: 58rpx;
							text-align: center;

							>text {
								font-size: 24rpx;
								font-weight: 600;
								color: #FFFFFF;
								line-height: 52rpx;
							}
						}
					}
				}
			}
		}
	}
</style>